package com.cy.letcode.珠心速算;

import java.util.Arrays;
import java.util.HashMap;
import java.util.Map;

/**
 * 珠玑妙算游戏（the game of master mind）的玩法如下。
 * <p>
 * 计算机有4个槽，每个槽放一个球，颜色可能是红色（R）、黄色（Y）、绿色（G）或蓝色（B）。例如，计算机可能有RGGB 4种（槽1为红色，槽2、3为绿色，槽4为蓝色）。作为用户，你试图猜出颜色组合。打个比方，你可能会猜YRGB。要是猜对某个槽的颜色，则算一次“猜中”；要是只猜对颜色但槽位猜错了，则算一次“伪猜中”。注意，“猜中”不能算入“伪猜中”。
 * <p>
 * 给定一种颜色组合solution和一个猜测guess，编写一个方法，返回猜中和伪猜中的次数answer，其中answer[0]为猜中的次数，answer[1]为伪猜中的次数。
 * <p>
 * 示例：
 * <p>
 * 输入： solution="RGBY",guess="GGRR"
 * 输出： [1,1]
 * 解释： 猜中1次，伪猜中1次。
 * 提示：
 * <p>
 * len(solution) = len(guess) = 4
 * solution和guess仅包含"R","G","B","Y"这4种字符
 * <p>
 * 1 1 0 2
 * 来源：力扣（LeetCode）
 * 链接：https://leetcode-cn.com/problems/master-mind-lcci
 * 著作权归领扣网络所有。商业转载请联系官方授权，非商业转载请注明出处。
 */
class Solution {
    public static void main(String[] args) {
        int[] ints = new Solution().masterMind("RGBY", "GGRR");
        System.out.println(Arrays.toString(ints));
    }

    public int[] masterMind(String solution, String guess) {
        int[] flag = new int[26];
        //1 2 3 4
        int real = 0;
        int allNum = 0;
        for (int i = 0; i < 4; i++) {
            if (solution.charAt(i) == guess.charAt(i)) {
                real++;
            }
            int indexSo = solution.charAt(i) - 'A';
            int indexGuess = guess.charAt(i) - 'A';
            if (flag[indexSo] < 0) {
                allNum++;
            }
            flag[indexSo]++;
            if (flag[indexGuess] > 0) {
                allNum++;
            }
            flag[indexGuess]--;
        }
        return new int[]{real, allNum - real};

    }
}